home *** CD-ROM | disk | FTP | other *** search
/ EnigmA Amiga Run 1997 May / EnigmA AMIGA RUN 18 (1997)(G.R. Edizioni)(IT)[!][issue 1997-05][EAR-CD II].iso / earcd / dev / gcc / ixemulsd.lha / include / nfs / xdr_subs.h < prev   
Text File  |  1996-12-11  |  4KB  |  84 lines

  1. /*    $NetBSD: xdr_subs.h,v 1.8 1995/01/13 16:15:02 mycroft Exp $    */
  2.  
  3. /*
  4.  * Copyright (c) 1989, 1993
  5.  *    The Regents of the University of California.  All rights reserved.
  6.  *
  7.  * This code is derived from software contributed to Berkeley by
  8.  * Rick Macklem at The University of Guelph.
  9.  *
  10.  * Redistribution and use in source and binary forms, with or without
  11.  * modification, are permitted provided that the following conditions
  12.  * are met:
  13.  * 1. Redistributions of source code must retain the above copyright
  14.  *    notice, this list of conditions and the following disclaimer.
  15.  * 2. Redistributions in binary form must reproduce the above copyright
  16.  *    notice, this list of conditions and the following disclaimer in the
  17.  *    documentation and/or other materials provided with the distribution.
  18.  * 3. All advertising materials mentioning features or use of this software
  19.  *    must display the following acknowledgement:
  20.  *    This product includes software developed by the University of
  21.  *    California, Berkeley and its contributors.
  22.  * 4. Neither the name of the University nor the names of its contributors
  23.  *    may be used to endorse or promote products derived from this software
  24.  *    without specific prior written permission.
  25.  *
  26.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  27.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  28.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  29.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  30.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  31.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  32.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  33.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  34.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  35.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  36.  * SUCH DAMAGE.
  37.  *
  38.  *    @(#)xdr_subs.h    8.1 (Berkeley) 6/10/93
  39.  */
  40.  
  41. /*
  42.  * Macros used for conversion to/from xdr representation by nfs...
  43.  * These use the MACHINE DEPENDENT routines ntohl, htonl
  44.  * As defined by "XDR: External Data Representation Standard" RFC1014
  45.  *
  46.  * To simplify the implementation, we use ntohl/htonl even on big-endian
  47.  * machines, and count on them being `#define'd away.  Some of these
  48.  * might be slightly more efficient as quad_t copies on a big-endian,
  49.  * but we cannot count on their alignment anyway.
  50.  */
  51.  
  52. #define    fxdr_unsigned(t, v)    ((t)ntohl((long)(v)))
  53. #define    txdr_unsigned(v)    (htonl((long)(v)))
  54.  
  55. #define    fxdr_nfstime(f, t) { \
  56.     (t)->ts_sec = ntohl(((struct nfsv2_time *)(f))->nfs_sec); \
  57.     if (((struct nfsv2_time *)(f))->nfs_usec != 0xffffffff) \
  58.         (t)->ts_nsec = 1000 * ntohl(((struct nfsv2_time *)(f))->nfs_usec); \
  59.     else \
  60.         (t)->ts_nsec = 0; \
  61. }
  62. #define    txdr_nfstime(f, t) { \
  63.     ((struct nfsv2_time *)(t))->nfs_sec = htonl((f)->ts_sec); \
  64.     ((struct nfsv2_time *)(t))->nfs_usec = htonl((f)->ts_nsec) / 1000; \
  65. }
  66.  
  67. #define    fxdr_nqtime(f, t) { \
  68.     (t)->ts_sec = ntohl(((struct nqnfs_time *)(f))->nq_sec); \
  69.     (t)->ts_nsec = ntohl(((struct nqnfs_time *)(f))->nq_nsec); \
  70. }
  71. #define    txdr_nqtime(f, t) { \
  72.     ((struct nqnfs_time *)(t))->nq_sec = htonl((f)->ts_sec); \
  73.     ((struct nqnfs_time *)(t))->nq_nsec = htonl((f)->ts_nsec); \
  74. }
  75.  
  76. #define    fxdr_hyper(f, t) { \
  77.     ((long *)(t))[_QUAD_HIGHWORD] = ntohl(((long *)(f))[0]); \
  78.     ((long *)(t))[_QUAD_LOWWORD] = ntohl(((long *)(f))[1]); \
  79. }
  80. #define    txdr_hyper(f, t) { \
  81.     ((long *)(t))[0] = htonl(((long *)(f))[_QUAD_HIGHWORD]); \
  82.     ((long *)(t))[1] = htonl(((long *)(f))[_QUAD_LOWWORD]); \
  83. }
  84.